package com.yiruantong.outbound.domain.service.api;

import jakarta.validation.constraints.NotBlank;
import jakarta.validation.constraints.NotNull;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.NoArgsConstructor;
import com.yiruantong.common.core.validate.AddGroup;
import com.yiruantong.common.core.validate.EditGroup;

import java.math.BigDecimal;
import java.util.Date;
import java.util.Map;


/**
 * 出库退货单明细业务对象 out_return_detail
 *
 * @author YiRuanTong
 * @date 2024-11-02
 */

@Data
@NoArgsConstructor
@EqualsAndHashCode(callSuper = false)
public class ApiOutReturnDetailBo {

  /**
   * 退货单明细ID
   */
  private Long returnDetailId;

  /**
   * 退货单ID
   */
  private Long returnId;

  /**
   * 销售明细ID
   */
  private Long orderDetailId;

  /**
   * 销售ID
   */
  private Long orderId;

  /**
   * 产品ID
   */
  private Long productId;

  /**
   * 产品编号
   */
  @NotBlank(message = "产品编号不能为空", groups = {AddGroup.class, EditGroup.class})
  private String productCode;

  /**
   * 产品名称
   */
  private String productName;

  /**
   * 条形码
   */
  private String productModel;

  /**
   * 商品规格
   */
  private String productSpec;

  /**
   * 货位名称
   */
  private String positionName;

  /**
   * 小单位
   */
  private String smallUnit;

  /**
   * 大单位
   */
  private String bigUnit;

  /**
   * 订购数量
   */
  @NotNull(message = "订购数量不能为空", groups = {AddGroup.class, EditGroup.class})
  private BigDecimal orderQuantity;

  /**
   * 退货数量
   */
  private BigDecimal returnQuantity;

  /**
   * 已出货数量
   */
  private Long outedQuantity;

  /**
   * 重量
   */
  private BigDecimal weight;

  /**
   * 小计毛重
   */
  private BigDecimal rowWeight;

  /**
   * 换算关系
   */
  private BigDecimal unitConvert;

  /**
   * 单位关系
   */
  private String unitConvertText;

  /**
   * 成本价
   */
  private BigDecimal purchasePrice;

  /**
   * 成本总额
   */
  private BigDecimal purchaseAmount;

  /**
   * 退款售价
   */
  private BigDecimal salePrice;

  /**
   * 退款金额
   */
  private BigDecimal saleAmount;

  /**
   * 税率
   */
  private BigDecimal rate;

  /**
   * 税价
   */
  private BigDecimal ratePrice;

  /**
   * 价税合计
   */
  private BigDecimal rateAmount;

  /**
   * 缺货数量
   */
  private Long lackStorage;

  /**
   * 分拣状态
   */
  private Long sortingStatus;

  /**
   * SN
   */
  private String singleSignCode;

  /**
   * 批次号
   */
  private String batchNumber;

  /**
   * 排序号
   */
  private Long orderNum;

  /**
   * 扩展字段
   */
  private Map<String, Object> expandFields;

  /**
   * 备注
   */
  private String remark;

  /**
   * 删除时间
   */
  private Date deleteTime;

  /**
   * 删除人id
   */
  private Long deleteBy;

  /**
   * 删除人
   */
  private String deleteByName;

  /**
   * 单位净重
   */
  private BigDecimal netWeight;

  /**
   * 小计净重
   */
  private BigDecimal rowNetWeight;

  /**
   * 来源类别
   */
  private String sourceType;

  /**
   * 来源主表ID
   */
  private String sourceMainId;

  /**
   * 来源明细ID
   */
  private String sourceDetailId;

  /**
   * 大单位数量
   */
  private BigDecimal bigQty;

  /**
   * 单位体积
   */
  private BigDecimal unitCube;

  /**
   * 小计体积
   */
  private BigDecimal rowCube;

  /**
   * 实退数量
   */
  private BigDecimal actualReturnQuantity;

  /**
   * 温层
   */
  private String thermocline;

  /**
   * 商品品牌
   */
  private String brandName;

  /**
   * 商品类别
   */
  private String typeName;

  /**
   * 商品型号
   */
  private String productBarCode;

  /**
   * 图片
   */
  private String images;

  /**
   * 生产日期
   */
  private Date produceDate;

  /**
   * 供应商ID
   */
  private Long providerId;

  /**
   * 供应商编号
   */
  private String providerCode;

  /**
   * 供应商名称
   */
  private String providerShortName;

  /**
   * 已收货数量
   */
  private BigDecimal enterQuantity;


}
